package com.atguigu.gulimall.seckill;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

/**
 * 1整合sentinel
 *   1,导入依赖  spring-cloud-starter-alibaba-sentinel
 *   2，下载sentinel 的控制台
 *   3，配置sentinel 控制台地址信息
 *   4，在控制台调整参数。【默认所有的流控设置保存在内存中，重启失效】
 * 2：每一个微服务都导入spring-boot-starter-actuator依赖处理sentienl图表审计
 *    并配置management.endpoints.web.exposure.include=* 暴露所有端点信息
 * 3：自定义sentinel流控返回数据
 * 4:使用sentinel 来保护feign 远程调用：熔断
 *      1：调用方法的熔断保护： feign.sentinel.enabled=true
 *      2：调用方手动指定远程服务的降级策略。远程服务被降级处理，触发我们的熔断回调方法
 *      3: 超大流量的时候，必须牺牲一些远程服务。在服务的提供方（远程服务）指定降级策略；
 *         提供方是在运行。但是不运行自己的业务逻辑，返回的是默认的降级数据（限流的数据）
 *  5:自定义受保护的资源
 *      1：代码： try(Entry entry = SphU.entry("seckillSkus")){}catch(Execption e)
 *      2：注解： @SentinelResource(value = "getCurrentSeckillSkusResource",blockHandler = "blockHandler")
 *      无论是1，2方式一定要配置被限流后的默认返回，url请求可以设置同一返回：WebCallbackManager
 *
 * @author xiaoping
 */
@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
public class GulimallSeckillApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallSeckillApplication.class, args);
    }

}
